<?php

$user = exec('whoami');
echo "当前运行用户为：" . $user;
// 项目存放物理路径
$savePath = "/var/www/tp";
// 代码仓库
$gitPath  = "git@gitee.com:td_lj/tp.git";

// 获取钩子post参数
$requestBody = file_get_contents("php://input");
if (empty($requestBody)) {
    die('send fail');
}

// 解析Git服务器通知过来的JSON信息
$content = json_decode($requestBody, true);
$res = PHP_EOL . "pull start ------------------"; // PHP_EOL 代表 \r\n 换行
$res .= ' <' . implode('', array_column($content['commits'], 'message')) . '>' . PHP_EOL; // commit 版本名称

// 拉取代码
$shell_res = shell_exec("cd {$savePath} && sudo git pull {$gitPath}");
if( $shell_res === null ){
    echo 'Error';die;
}


$res .= $shell_res;

// 日志编写
$res_log = PHP_EOL . '>>>>>>>>>>>>========================================<<<<<<<<<<<<' . PHP_EOL . PHP_EOL;
$res_log .= '【' . $content['user_name'] . '】在【' . date('Y-m-d H:i:s');            // 谁在什么时间
$res_log .= '】向【' . $content['repository']['name'] . '】项目的【' . $content['ref'] . '】'; // 向谁的什么
$res_log .= '分支push了' . $content['total_commits_count'] . '个commit：' . PHP_EOL;  // 怎么做了什么事情
$res_log .= $res; // 放入git记录代码
$res_log .= "pull end --------------------" . PHP_EOL;

// 写入日志到log文件中
file_put_contents("git-webhook_log.txt", $res_log, FILE_APPEND);
echo $res;
echo 'Success';die;